package com.vehiclemanagement.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import lombok.ToString;

import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * ETC停车记录实体类
 */
@Data
@ToString(callSuper = true)
@TableName("etc_parking")
public class ETCParking implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 停车记录ID
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;

    /**
     * 车辆ID
     */
    @TableField("vehicle_id")
    private Long vehicleId;

    /**
     * 驾驶员ID
     */
    @TableField("driver_id")
    private Long driverId;

    /**
     * ETC卡ID
     */
    @TableField("etc_card_id")
    private Long etcCardId;

    /**
     * 停车场名称
     */
    @TableField("parking_name")
    private String parkingName;

    /**
     * 入场时间
     */
    @TableField("entry_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime entryTime;

    /**
     * 出场时间
     */
    @TableField("exit_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime exitTime;

    /**
     * 停车时长（分钟）
     */
    @TableField("duration")
    private Integer duration;

    /**
     * 停车费用
     */
    @TableField("fee")
    private BigDecimal fee;

    /**
     * 停车类型：1-路边停车，2-停车场，3-地下车库
     */
    @TableField("parking_type")
    private Integer parkingType;

    /**
     * 状态：1-已创建，2-已结算，3-异常
     */
    @TableField("status")
    private Integer status;
    
    /**
     * 交易流水号
     */
    @TableField("transaction_no")
    private String transactionNo;

    /**
     * 备注
     */
    @TableField("remark")
    private String remark;

    /**
     * 创建时间
     */
    @TableField("create_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime createTime;

    /**
     * 更新时间
     */
    @TableField("update_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime updateTime;

    /**
     * 删除标志：0-未删除，1-已删除
     */
    @TableField("del_flag")
    @TableLogic
    private Integer delFlag;

    /**
     * 非数据库字段 - 车牌号
     */
    @TableField(exist = false)
    private String plateNumber;

    /**
     * 非数据库字段 - 驾驶员姓名
     */
    @TableField(exist = false)
    private String driverName;

    /**
     * 非数据库字段 - ETC卡号
     */
    @TableField(exist = false)
    private String etcCardNumber;

    /**
     * 非数据库字段 - 停车类型名称
     */
    @TableField(exist = false)
    private String parkingTypeName;
    
    /**
     * 非数据库字段 - 状态名称
     */
    @TableField(exist = false)
    private String statusName;
} 